<template>
  <div class="app-container">
    <!-- 查询条件开始 -->
    <el-form
      ref="queryForm"
      :model="queryParams"
      :inline="true"
      label-width="68px"
    >
      <el-form-item label="用户名称" prop="userName">
        <el-input
          v-model="queryParams.userName"
          placeholder="请输入用户名称"
          clearable
          size="small"
          style="width: 200px"
        />
      </el-form-item>
      <el-form-item label="用户账号" prop="loginAccount">
        <el-input
          v-model="queryParams.loginAccount"
          placeholder="请输入用户账号"
          clearable
          size="small"
          style="width: 200px"
        />
      </el-form-item>
      <el-form-item label="IP地址" prop="ipAddr">
        <el-input
          v-model="queryParams.ipAddr"
          placeholder="请输入IP地址"
          clearable
          size="small"
          style="width: 200px"
        />
      </el-form-item>
      <el-form-item label="登陆状态" prop="loginStatus">
        <el-select
          v-model="queryParams.loginStatus"
          placeholder="请选择登陆状态"
          clearable
          size="small"
          style="width: 200px"
        >
          <el-option
            v-for="dict in statusOptions"
            :key="dict.dictValue"
            :label="dict.dictLabel"
            :value="dict.dictValue"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="登陆类型" prop="loginType">
        <el-select
          v-model="queryParams.loginType"
          placeholder="请选择登陆类型"
          clearable
          size="small"
          style="width: 200px"
        >
          <el-option
            v-for="dict in loginTypeOptions"
            :key="dict.dictValue"
            :label="dict.dictLabel"
            :value="dict.dictValue"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="创建时间">
        <el-date-picker
          v-model="dateRange"
          size="small"
          style="width: 240px"
          value-format="yyyy-MM-dd"
          type="daterange"
          range-separator="-"
          start-placeholde="开始日期"
          end-placeholde="结束日期"
        />
      </el-form-item>
      <el-form-item>
        <el-button
          type="primary"
          icon="el-icon-search"
          size="mini"
          @click="handleQuery"
          >搜索</el-button
        >
        <el-button
          type="normal"
          icon="el-icon-refresh"
          size="mini"
          @click="resetQuery"
          >重置</el-button
        >
      </el-form-item>
    </el-form>
    <!-- 查询条件结束 -->
    <!-- 工具栏开始 -->
    <el-row :gutter="10" style="margin-bottom: 8px">
      <el-col :span="1.5">
        <el-button
          type="danger"
          icon="el-icon-delete"
          size="mini"
          :disabled="multiple"
          @click="handleDelete"
          >删除</el-button
        >
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          icon="el-icon-thumb"
          size="mini"
          @click="handleClearInfo"
          >清空</el-button
        >
      </el-col>
    </el-row>
    <!-- 工具栏结束 -->

    <!-- 数据表格开始 -->
    <el-table
      v-loading="loading"
      border
      :data="loginInfoTableList"
      @selection-change="handleSelectionChange"
    >
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="日志ID" align="center" prop="infoId" />
      <el-table-column label="用户姓名" align="center" prop="userName" />
      <el-table-column label="登陆帐号" align="center" prop="loginAccount" />
      <el-table-column label="IP" width="180" align="center" prop="ipAddr" />
      <el-table-column label="登陆地址" align="center" prop="loginLocation" />
      <el-table-column label="浏览器" align="center" prop="browser" />
      <el-table-column label="操作系统" align="center" prop="os" />
      <el-table-column
        label="登陆状态"
        prop="loginStatus"
        align="center"
        :formatter="statusFormatter"
      />
      <el-table-column
        label="用户类型"
        prop="loginType"
        align="center"
        :formatter="loginTypeFormatter"
      />
      <el-table-column
        label="登陆时间"
        align="center"
        prop="loginTime"
        width="200"
      />
      <el-table-column label="操作" align="center" width="100">
        <template slot-scope="scope">
          <el-button
            v-if="scope.row.userId != 1"
            type="text"
            icon="el-icon-delete"
            size="mini"
            @click="handleDelete(scope.row)"
            >删除</el-button
          >
        </template>
      </el-table-column>
    </el-table>
    <!-- 数据表格结束 -->

    <!-- 分页控件开始 -->
    <el-pagination
      v-show="total > 0"
      :current-page="queryParams.pageNum"
      :page-sizes="[5, 10, 20, 30]"
      :page-size="queryParams.pageSize"
      layout="total,sizes,prev,pager,next,jumper"
      :total="total"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
    />
    <!-- 分页控件结束 -->
  </div>
</template>

<script >
// 引入接口
import {
  loadAllLoginLogs,
  removeLoginLog,
  clearAllLoginLogs,
} from "@/api/system/loginLog/logininfo";
import { loadDictDataByType } from "@/api/system/dict/data";
export default {
  data() {
    return {
      // 遮罩层
      loading: false,
      // 选中多条
      multiple: true,
      // 选中数组
      ids: [],
      // 总条数
      total: 0,
      // 用户数据数据
      loginInfoTableList: [],
      // 登陆状态数据字典
      statusOptions: [],
      // 登陆类型数据字典
      loginTypeOptions: [],
      // 时间
      dateRange: [],
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        userName: undefined,
        loginAccount: undefined,
        loginStatus: undefined,
        loginType: undefined,
      },
    };
  },
  created() {
    // 加载查询条件状态
    loadDictDataByType("sys_common_status").then((res) => {
      this.statusOptions = res.data.dataList;
    });
    // 加载用户级别
    loadDictDataByType("sys_user_type").then((res) => {
      this.loginTypeOptions = res.data.dataList;
    });
    this.getLoginInfoList();
  },
  methods: {
    // 查询用户信息
    getLoginInfoList() {
      this.loading = true;
      loadAllLoginLogs(
        this.addDateRange(this.queryParams, this.dateRange)
      ).then((res) => {
        this.loginInfoTableList = res.data;
        this.total = res.data.total;
        this.loading = false;
      });
    },
    // 每页显示多少条的数据变化
    handleSizeChange(val) {
      this.queryParams.pageSize = val;
      this.getLoginInfoList();
    },
    // 分页跳转
    handleCurrentChange(val) {
      this.queryParams.pageNum = val;
      this.getLoginInfoList();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map((item) => item.infoId);
      this.multiple = !selection.length;
    },
    // 查询
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.getLoginInfoList();
    },
    // 重置
    resetQuery() {
      this.dateRange = [];
      this.resetForm("queryForm");
      this.getLoginInfoList();
    },
    // 翻译登陆状态
    statusFormatter(row) {
      return this.selectDictLabel(this.statusOptions, row.loginStatus);
    },
    // 翻译登陆类型
    loginTypeFormatter(row) {
      return this.selectDictLabel(this.loginTypeOptions, row.loginType);
    },
    // 删除
    handleDelete(row) {
      const tx = this;
      const logIds = row.infoId || this.ids;
      this.$confirm("是否确认删除登陆日志ID为:" + logIds + "的数据?", "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
      })
        .then(function () {
          removeLoginLog(logIds).then((res) => {
            tx.getLoginInfoList();
            tx.msgSuccess("删除成功");
          });
        })
        .catch(function () {
          tx.msgSuccess("删除已取消");
        });
    },
    // 清空
    handleClearInfo() {
      const tx = this;
      this.$confirm("是否确认清空登陆日志的数据?", "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
      })
        .then(function () {
          clearAllLoginLogs().then((res) => {
            tx.getLoginInfoList();
            tx.msgSuccess("清空成功");
          });
        })
        .catch(function () {
          tx.msgSuccess("删除失败");
        });
    },
  },
};
</script>
